<template>
  <div class="card-container">
    <!-- 搜索区域 -->
    <div class="search-container">
      <span class="search-label">车牌号码：</span>
      <el-input v-model="params.carNumber" clearable placeholder="请输入内容" class="search-main" />
      <span class="search-label">车主姓名：</span>
      <el-input v-model="params.personName" clearable placeholder="请输入内容" class="search-main" />
      <span class="search-label">状态：</span>
      <el-select v-model="params.cardStatus" style="width: 240px">
        <el-option v-for="item in cardStatusList" :key="item.id" :value="item.id" :label="item.name"  />
      </el-select>
      <el-button type="primary" class="search-btn" @click="SearchList">查询</el-button>
    </div>
    <!-- 新增删除操作区域 -->
    <div class="create-container">
      <el-button type="primary" @click="$router.push('/cardAdd')">添加月卡</el-button>
      <el-button>批量删除</el-button>
    </div>
    <!-- 表格区域 -->
    <div class="table">
      <el-table style="width: 100%" :data="ListData">
        <el-table-column align="center" type="index" label="序号" width="100" />
        <el-table-column align="center" label="车主名称" prop="personName" />
        <el-table-column align="center" label="联系方式" prop="phoneNumber" />
        <el-table-column align="center" label="车牌号码" prop="carNumber" />
        <el-table-column align="center" label="车辆品牌" prop="carBrand" />
        <el-table-column align="center" label="剩余有效天数" prop="totalEffectiveDate" :formatter="formatData"/>
        <el-table-column align="center" label="状态" prop="cardStatus" :formatter="formatStatus" />
        <el-table-column align="center" label="操作" fixed="right" width="260">
          <template  #default="scope">
            <el-button size="small" type="text">续费</el-button>
            <el-button size="small" type="text">查看</el-button>
            <el-button size="small" type="text">编辑</el-button>
            <el-button size="small" type="text">删除</el-button>
          </template>
        </el-table-column>
      </el-table>
    </div>
    <!-- 分页 -->
    <div class="page-container" style="float: right;margin-top: 10px;">
      <el-pagination 
      v-model:current-page="params.page"
      v-model:page-size="params.pageSize"
      :page-sizes="[5, 10, 15, 20]"
      size="default"
      layout="total, prev, pager, next,sizes" 
      :total=total
      @current-change="PageChange" />
    </div>
  </div>
</template>

<script lang="ts" setup>
import { getCardListAPI } from '@/apis/card';
import type { Card, CardListParams } from '@/types/card';
import { ref } from 'vue';

const  formatStatus=(row:Card)=>{
  return  row.cardStatus===0?'可用':'已过期' 
}
const  formatData=(row:Card)=>{
  return  row.totalEffectiveDate+'天'
}



//参数设置
const params=ref<CardListParams>({
  page:1,
  pageSize:5,
  carNumber:undefined,   //车辆号码
  personName:undefined,  //车主姓名
  cardStatus:undefined,  //月卡状态
})

//获取月卡列表数据
const ListData=ref<Card[]>([])
const total=ref(0)
const getListData=async ()=>{
  const tempParams={...params.value}
  if(tempParams.cardStatus =='-1'){
    delete tempParams.cardStatus
  }
  const res=await getCardListAPI(params.value)
  ListData.value=res.data.rows
  total.value=res.data.total
}

//分页
const PageChange=(page:number)=>{
  // console.log(page)
  params.value.page=page
  getListData()
}
const SizeChange=(pagesize:number)=>{
  params.value.pageSize=pagesize
  getListData()
}

getListData()

// 搜索
//月卡状态
const cardStatusList=[
  {id:-1,name:'全部'},
  {id:0,name:'可用'},
  {id:1,name:'已过期'}]

  const  SearchList=()=>{
    //将页数设置为1
    params.value.page=1
    getListData()
  }





</script>

<style lang="scss" scoped>
.card-container {
  padding: 20px;
  background-color: #fff;
}

.search-container {
  display: flex;
  align-items: center;
  border-bottom: 1px solid rgb(237, 237, 237, .9);
  padding-bottom: 20px;

  .search-main {
    width: 220px;
    margin-right: 10px;
  }

  .search-btn {
    margin-left: 20px;
  }
}

.create-container {
  margin: 10px 0px;
}

.page-container {
  padding: 4px 0px;
  text-align: right;
}

.form-container {
  padding: 0px 80px;
}
</style>